Z-80® CTC 

Counter/Timer 

Circuit 




Zilog 



Product 
Specification 



February 1980 



Features ■ Four independently programmable 

counter/timer channels, each with a 
readable downcounter and a selectable 
16 or 256 prescaler. Downcounters are 
reloaded automatically at zero count. 

■ Standard Z-80 Family daisy-chain interrupt 
structure provides fully vectored, prioritized 
interrupts without external logic. The CTC 
may also be used as an interrupt controller. 



Selectable positive or negative trigger 
initiates timer operation. 

Three channels have Zero Count/Timeout 
outputs capable of driving Darlington 
transistors. 

Interfaces directly to the Z-80 CPU or — for 
baud rate generation — to the Z-80 SIO. 



Description The Z-80 CTC four-channel counter/timer 

can be programmed by system software for a 
broad range of counting and timing applica- 
tions. The four independently programmable 
channels of the Z-80 CTC satisfy common 
microcomputer system reguirements for event 
counting, interrupt and interval timing, and 
general clock rate generation. - 

System design is simplified because the CTC 
connects directly to both the Z-80 CPU and the 
Z-80 SIO with no additional logic. In larger 
systems, address decoders and buffers may be 
reguired. 

Programming the CTC is straightforward; 



each channel is programmed with two bytes; a 
third is necessary when interrupts are enabled. 
Once started, the CTC counts down, reloads 
its time constant automatically, and resumes 
counting. Software timing loops are completely 
eliminated. Interrupt processing is simplified 
because only one vector need be specified; the 
CTC internally generates a unique vector for 
each channel. 

The Z-80 CTC requires a single -I- 5 V power 
supply and the standard Z-80 single-phase 
system clock. It is fabricated with n-channel 
silicon-gate depletion-load technology, and 
packaged in a 28-pin plastic or ceramic DIP. 
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Figure 1. Pin Functions 



Figure 2. Pin Assignments 
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Functional The Z-80 CTC has four independent counter/ 

Description timer channels. Each channel is individually 
programmed with two words: a control word 
and a time- constant word. The control word 
selects the operating mode (counter or timer), 
enables or disables the channel interrupt, and 
selects certain other operating parameters. If 
the timing mode is selected, the control word 
also sets a prescaler, which divides the system 
clock by either 16 or 256. The time- constant 
word is a value from 1 to 256. 

During operation, the individual counter 
channel counts down from the preset time con- 
stant value. In counter mode operation the 
counter decrements on each of the CLK/TRG 
input pulses until zero count is reached. Each 
decrement is synchronized by the system 
clock. For counts greater than 256, more than 
one counter can be cascaded. At zero count, 
the down-counter is automatically reset with 
the time constant value. 

The timer mode determines time intervals as 
small as 4 fis (Z-80A) or 6.4 pes (Z-80) without 
additional logic or software timing loops. Time 
intervals are generated by dividing the system 
clock with a prescaler that decrements 



a preset down- counter. 

Thus, the time interval is an integral mul- 
tiple of the clock period, the prescaler value 
(16 or 256) and the time constant that is preset 
in the down- counter. A timer is triggered auto- 
matically when its time constant value is pro- 
grammed, or by an external CLK/TRG input. 

Three channels have two outputs that occur 
at zero count. The first output is a zero- 
count/timeout pulse at the ZC/TO output. The 
fourth channel (Channel 3) does not have a 
ZC/TO output; interrupt request is the only 
output available from Channel 3. 

Th e second output is Interrupt Request 
(INT), which occurs if the channel has its 
interrupt enabled during programming. When 
the Z-80 CPU acknowledges Interrupt Request, 
the Z-80 CTC places an interrupt vector on the 
data bus. 

The four channels of the Z-80 CTC are fully 
prioritized and fit into four contiguous slots in 
a standard Z-80 daisy-chain interrupt struc- 
ture. Channel 0 is the highest priority and 
Channel 3 the lowest. Interrupts can be 
individually enabled (or disabled) for each of 
the four channels. 



Architecture The CTC has four major elements, as shown 
in Figure 3. 

■ CPU bus I/O 

■ Channel control logic 

■ Interrupt logic 

■ Counter/timer circuits 

CPU Bus I/O. The CPU bus I/O circuit 
decodes the address inputs, and interfaces the 
CPU data and control signals to the CTC for 
distribution on the internal bus. 



Internal Control Logic. The CTC internal 
control logic controls overall chip operating 
functions such as the chip enable, reset, and 
read/write logic. 

Interrupt Logic. The interrupt control logic 
ensures that the CTC interrupts interface prop- 
erly with the Z-80 CPU interrupt system. The 
logic controls the interrupt priority of the CTC 
as a function of the lEI signal. If lEI is High, 
the CTC has priority. During interrupt 
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Figure 3. Functional Block Diagram 
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Architecture processing, the interrupt logic holds lEO Low, 
(Continued) which inhibits the interrupt operation on lower 
priority devices. If the lEI input goes Low, 
priority is relinquished and the interrupt logic 
drives lEO Low. 

If a channel is programmed to request an 
interrupt, the interrupt logic driv es lE O Low at 
the zero count, and generates an INT signal to 
the Z-80 CPU. When- the Z-80CPU responds 
with interrupt acknowledge (Ml and lORQ), 
then the interrupt logic arbitrates the CTC 
internal priorities, and the interrupt control 
logic places a unique interrupt vector on the 
data bus. 

If an interrupt is pending, the interrupt logic 
holds lEO Low. When the Z-80 CPU issues a 
Return From Interrupt (RETI) instruction, each 
peripheral device decodes the first byte 
(ED is). If the device has a pending interrupt, 
it raises lEO (High) for one Ml cycle. This 
ensures that all lower priority devices can 
decode the entire RETI instruction and reset 
properly. 



CHANNEL 
CONTROL 
LOGIC 



INTERNAL BUS 



TIME 
CONSTANT 
REGISTER 



8BIT 
DOWN- 
COUNTER 



Figure 4. Counter/ Timer Block Diagram 

Counter/Timer Circuits. The CTC has four 
independent counter/timer circuits, each con- 
taining the logic shown in Figure 4. 

Channel Control Logic. The channel control 
logic receives the 8-bit channel control word 
when the counter/timer channel is pro- 
grammed. The channel control logic decodes 



the control word and sets the following 
operating conditions: 

■ Interrupt enable (or disable) 

■ Operating mode (timer or counter) 

■ Timer mode prescaler factor (16 or 256) 

■ Active slope for CLK/TRG input 

■ Timer mode trigger (automatic or CLK/TRG 
input) 

■ Time constant data word to follow 

■ Software reset 

Time Constant Register. When the counter/ 
timer channel is programmed, the time con- 
stant register receives and stores an 8-bit time 
constant value, which can be anywhere from 1 
to 256 (0 = 256). This constant is automatic- 
ally loaded into the down-counter when the 
counter/timer channel is initialized, and subse- 
guently after each zero count. 

Prescaler. The prescaler, which is used only 
in timer mode, divides the system clock fre- 
guency by a factor of either 16 or 256. The 
prescaler output clocks the down-counter dur- 
ing timer operation. The effect of the prescaler 
on the down-counter is a multiplication of the 
system clock period bf 16 or 256. The pre- 
scaler factor is programmed by bit 5 of the 
channel control word. 

Down-Counter. Prior to each count cycle, the 
down-counter is loaded with the time constant 
register contents. The counter is then 
decremented one of two ways, depending on 
operating mode: 

■ By the prescaler output (timer mode) 

■ By the trigger pulses into the CLK/TRG 
input (counter mode) 

Without disturbing the down-count, the Z-80 
CPU can read the count remaining at any time 
by performing an I/O read operation at the 
port address assigned to the CTC channel. 
When the down-counter reaches the zero 
count, the ZC/TO output generates a positive- 
going pulse. When the interrupt is enabled, 
zero co unt also triggers an interrupt reguest 
signal (INT) from the interrupt logic. 
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Programming Each Z-80 CTC channel must be pro- 
grammed prior to operation. Programming 
consists of writing two words to the I/O port 
that corresponds to the desired channel. The 
first word is a control word that selects the 
operating mode and other parameters; the 
second word is a time constant, which is a 
binary data word with a value from 1 to 256. A 
time constant word must be preceded by a 
channel control word. 

After initialization, channels may be 
reprogrammed at any time. If updated control 
and time constant Words are written to a chan- 
nel during the count operation, the count con- 
tinues to zero before the new time constant is 
loaded into the counter. 

If the interrupt on any Z-80 CTC channel is 
enabled, the programming procedure should 
also include an interrupt vector. Only one vec- 
tor is reguired for all four channels, because 
the interrupt logic automatically modifies the 
vector for the channel reguesting service. 

A control word is identified by a 1 in bit 0. 
A 0 in bit 2 indicates a time constant word is to 
follow. Interrupt vectors are always addressed 
to Channel 0, and identified by a 0 in bit 0. 

Addressing. During programming, channels 
are addressed with the channel select pins CS] 
and CS2. A 2-bit binary code selects the 
appropriate channel as shown in the following 
table. 

Channel CSi CSq 
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Reset. The CTC has both hardware and soft- 
ware resets. The hardware reset terminates all 
down-counts and disables all CTC interrupts 
by resetting the interrupt bits in the control 
registers. In addition, the ZC/TO and Interrupt 
outputs go inactive, lEO reflects lEI, and 



D0-D7 go to the high- impedance state. All 
channels must be completely reprogrammed 
after a hardware reset. 

The software reset is controlled by bit 1 in 
the channel control word. When a channel 
receives a software reset, it stops counting. 
When a software reset is used, the other bits in 
the control word also change the contents of 
the channel control register. After a software 
reset a new time constant word must be written 
to the same channel. 

If the channel control word has both bits Di 
and D2 set to 1 , the addressed channel stops 
operating, pending a new time constant word. 
The channel is ready to resume after the new 
constant is programmed. In timer mode, if 
D3 = 0, operation is triggered automatically 
when the time constant word is loaded. 

Channel Control Word Programming. The 

channel control word is shown in Figure 5, It 
sets the modes and parameters described 
below. 

Interrupt Enable. D7 enables the interrupt, so 
that an interrupt output (INT) is generated at 
zero count. Interrupts may be programmed in 
either mode and may be enabled or disabled 
at any time. 

Operating Mode. Dq selects either timer or 
counter mode. 

Prescaler Factor. (Timer Mode Only). D5 

selects factor — either 16 or 256. 

Trigger Slope. D4 selects the active edge or 
slope of the CLK/TRG input pulses. Note that 
reprogramming the CLK/TRG slope during 
operation is eguivalent to issuing an active 
edge. If the trigger slope is changed by a con- 
trol word update while a channel is pending 
operation in timer mode, the result is the same 
as a CLK/TRG pulse and the timer starts. 
Similarly, if the channel is in counter mode, 
the counter decrements. 
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Figure 5. Channel Control Word 
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Programming Trigger Mode (Timer Mode Only). D3 selects 
(Continued) the trigger mode for timer operation. When D3 
is reset to 0, the timer is triggered automatic- 
ally. The time constant word is programmed 
during an I/O write operation, which takes one 
machine cycle. At the end of the write opera- 
tion there is a setup delay of one clock period. 
The timer starts automatically (decrements) on 
the rising edge of the second clock pulse (T2) 
of the machine cycle following the write opera- 
tion. Once started, the timer runs contin- 
uously. At zero count the timer reloads 
automatically and continues counting without 
interruption or delay, until stopped by a reset. 

When D3 is set to 1 , the timer is triggered 
externally through the CLK/TRG input. The 
time constant word is programmed during an 
I/O write operation, which takes one machine 
cycle. The timer is ready for operation on the 
rising edge of the second clock pulse (T2) of 
the following machine cycle. Note that the first 
timer decrement follows the active edge of the 
CLK/TRG pulse by a delay time of one clock 
cycle if a minimum setup time to the rising 
edge of clock is met. If this minimum is not 
met, the delay is extended by another clock 
period. Consequently, for immediate trigger- 
ing, the CLK/TRG input must precede T2 by 
one clock cycle plus its minimum setup time. If 
the minimum time is not met, the timer will 
start on the third clock cycle (T3). 

Once started the timer operates contin- 
uously, without interruption or delay, until 
stopped by a reset. 

Time Constant to Follow. A 1 in D2 indicates 
that the next word addressed to the selected 
channel is a time constant data word for the 
time constant register. The time constant word 
may be written at any time. 

A 0 in D2 indicates no time constant word is 
to follow. This is ordinarily used when the 
channel is already in operation and the new 
channel control word is an update. A channel 
will not operate without a time constant value. 
The only way to write a time constant value is 
to write a control word with D2 set. 



Software Reset. Setting D] to 1 causes a soft- 
ware reset, which is described in the Reset 
section. 

Control Word. Setting Dq to 0 identifies the 
word as a control word. 

Time Constant Programming. Before a chan- 
nel can start counting it must receive a time 
constant word from the CPU. During program- 
ming or reprogramming, a channel control 
word in which bit 2 is set must precede the 
time constant word to indicate that the next 
word is a time constant. The time constant 
word can be any value from 1 to 256 (Figure 
6). Note that 00 le is interpreted as 256. 

In timer mode, the time interval is controlled 
by three factors: 

■ The system clock period (</>) 

■ The prescaler factor (P), which multiplies 
the interval by either 16 or 256 

■ The time constant (T), which is programmed 
into the time constant register 

Consequently, the time interval is the pro- 
duct of </) X P X T. The minimum timer resolu- 
tion is 16 X 0 (4 ^s with a 4 MHz clock). The 
maximum timer interval is 256 x 0 x 256 (16.4 ms 
with a 4 MHz clock). For longer intervals 
timers may be cascaded. 

Interrupt Vector Programming. If the Z-80 
CTC has one or more interrupts enabled, it 
can supply interrupt vectors to the Z-80 CPU. 
To do so, the Z-80 CTC must be pre-pro- 
grammed with the most-significant five bits of 
the interrupt vector. Programming consists of 
writing a vector word to the I/O port cor- 
responding to the Z-80 CTC Channel 0. Note 
that Do of the vector word is always zero, to 
distinguish the vector from a channel control 
word. D] and D2 are not used in programming 
the vector word. These bits are supplied by 
the interrupt logic to identify the channel 
requesting interrupt service with a unique 
interrupt vector (Figure 7). Channel 0 has the 
highest priority. 
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Figure 7. Interrupt Vector Word 
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Pin CE. Chip Enable (input, active Low). When 

Description enabled the CTC accepts control words, inter- 
rupt vectors, or time constant data words from 
the data bus during an I/O write cycle; or 
transmits the contents of the down- counter to 
the CPU during an I/O read cycle. In most 
applications this signal is decoded from the 
eight least significant bits of the address bus 
for any of the four I/O port addresses that are 
mapped to the four counter-timer channels. 

CLK. System Clock (input). Standard single- 
phase Z-80 system clock. 

CLK/TRG0-CLK/TRG3. Externa] Clock/Timer 
Trigger (input, user- selectable active High or 
Low). Four pins corresponding to the four Z-80 
CTC channels. In counter mode, every active 
edge on this pin decrements the down- counter. 
In timer mode, an active edge starts the timer. 

CSq-CSi. Channel Select (inputs active High). 
Two-bit binary address code selects one of the 
four CTC channels for an I/O write or read 
(usually connected to Aq and A]). 

D0-D7. System Data Bus (bidirectional, 
3-state). Transfers all data and commands 
between the Z-80 CPU and the Z-80 CTC. 
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lEI. Interrupt Enable In (input, active High). 
A High indicates that no other interrupting 
devices of higher priority in the daisy chain 
are being serviced by the Z-80 CPU. 

lEO. Interrupt Enable Out (output, active 
High). High only if lEI is High and the Z-80 
CPU is not servicing an interrupt from any 
Z-80 CTC channel. lEO blocks lower priority 
devices from interrupting while a higher 
priority interrupting device is being serviced. 

INT. Interrupt Request (output, open drain, 
active Low). Low when any Z-80 CTC channel - 
that has been programmed to enable interrupts 
has a zero-count condition in its down-counter. 



lORQ. Input/Output Request (input from CPU, 
active Low). Used with CE and RD to transfer 
data and channel control words between the 
Z-80 C PU an d the Z-8 0 CTC. During_a_write 
cycle, lORQ and CE are active and RD 
inactive. The Z-80 CTC does not receive a 
specific write signal; rather, it internally 
generates its own from the inverse of a n active 
RD signal. In a read cycle, lORQ, CE and RD 
are active; the contents of the down - counter 
are read by the E-80 CPU. If lORQ and Ml are 
both true, the CPU is acknowledging an inter- 
rupt request, and the highest priority inter- 
rupting channel places its interrupt vector on 
the Z-80 data bus. 

ML Machine Cycle One (i nput fr om CPU, 
active Low). When Ml and lORQ are active, 
the Z-80 CPU is acknowledging an interrupt. 
The Z-80 CTC then places an interrupt vector 
on the data bus if it has highest priorit y, a nd if 
a channel has requested an interrupt (INT). 

RD. Read Cycle Status (i nput, a ctiv e Lo w). 
Used in conjunction with lORQ and CE to 
transfer data and channel control words 
between the Z-80 CPU and the Z-80 CTC. 



RESET. Reset (input active Low). Terminates 
all down-counts and disables all interrupts by 
resetting the interrupt bits in all control 
registers; the ZC/TO and the Interrupt outputs 
go inactive; lEO reflects lEI; D0-D7 go to the 
high-impedance state. 

ZC/TO0-ZC/TO2. Zero Count/Timeout (output, 
active High). Three ZC/TO pins corresponding 
to Z-80 CTC channels 2 through 0 (Channel 3 
has no ZC/TO pin). In both counter and timer 
modes the output is an active High pulse when 
the down-counter decrements to zero. 



Figure 8. A Typical Z-80 Environment 
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Timing Read Cycle Timing. Figure 9 shows read 

cycle timing. This cycle reads the contents of a 
down-counter without disturbing the count. 
During clock cycle T2/ the Z-80 CPU initiates a 
read cycle by dr iving the following inputs 
■Low: RD, lORQ, and CE. A 2-bit binary code 
at inputs CSi and CSq selects the channel to 
be read. Ml must be High to distinguish this 
cycle from an interrupt acknowledge. No addi- 
tional wait states are allowed. 



latched into the appropriate register with the 
rising edge of clock cycle T^A- No additional 
wait states are allowed. 




Figure 1 1 . Timer Mode Timing 
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Figure 9. Read Cycle Timing 

Write Cycle Timing. Figure 10 shows write 
cycle timing for loading control, time constant 
or vector words. 

The CTC does not have a write signal input, 
so it generates one internally when the read 
(RD) i nput is H igh during Ti. Dur ing T2 
lORQ and CE inputs are Low. Ml must be 
High to distinguish a write cycle from an inter- 
rupt acknowledge. A 2-bit binary code at 
inputs CSi and CSq selects the channel to be 
addressed, and the word being written is 
placed on the Z-80 data bus. The data word is 



Timer Operation. In the timer mode, a 
CLK/TRG pulse input starts the timer (Figure 
11) on the second succeeding rising edge of 
CLK. The trigger pulse is asynchronous, and it 
must have a minimum width. A minimum lead 
time (210 ns) is reguired between the active 
edge of the CLK/TRG and the next rising edge 
of CLK to enable the prescaler on the follow- 
ing clock edge. If the CLK/TRG edge occurs 
closer than this, the initiation of the timer 
function is delayed one clock cycle. This cor- 
responds to the startup timing discussed in the 
programming section. The timer can also be 
started automatically if so programmed by the 
channel control word. 
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Figure 12. Counter Mode Timing 
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Figure 10. Write Cycle Timing 



Counter Operation. In the counter mode, the 
CLK/TRG pulse input decrements the down- 
counter. The trigger is asynchronous, but the 
count is synchronized with CLK. For the 
decrement to occur on the next rising edge of 
CLK, the trigger edge must precede CLK by a 
minimum lead time as shown in Figure 12. If 
the lead time is less than specified, the count 
is delayed by one clock cycle. The trigger 
pulse must have a minimum width, and the 
trigger period must be at least twice the- clock 
period. 

The ZC/TO output occurs immediately after 
zero count, and follows the rising CLK edge. 



C8036-0162 C8036-0163 C8036-0164 C8036-0165 



Interrupt 
Operation 



The Z-80 CTC follows the Z-80 system inter- 
rupt protocol for nested priority interrupts and 
return from interrupt, wherein the interrupt 
priority of a peripheral is determined by its 
location in a daisy chain. Two lines — lEI and 
lEO — in the CTC connect it to the system daisy 
chain. The device closest to the + 5 V supply 
has the highest priority (Figure 13). For addi- 
tional information on the Z-80 interrupt struc- 
ture, refer to the Z-80 CPU Product Specifica- 
tion and the Z-80 CPU Technical Manual. 
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Figure 13. Daisy-Chain Interrupt Priorities 

Within the Z-80 CTC, interrupt priority is 
predetermined by channel number: Channel 0 
has the highest priority, and Channel 3 the 
lowest. If a device or channel is being serviced 
with an interrupt routine, it cannot be inter- 
rupted by a device or channel with lower 
priority until service is complete. Higher 
priority devices or channels may interrupt the 
servicing of lower priority devices or channels. 

A Z-80 CTC channel may be programmed to 
request an interrupt every time its down- 
counter reaches zero. Note that the CPU must 
be programmed for interrupt mode 2. Some 
time after the interrupt request, the CPU sends 
an interrupt acknowledge. The CTC interrupt 
control logic determines the highest priority 
channel that is requesting an interrupt. Then, 
if the CTC lEI input is High (indicating that it 
has priority within the system daisy chain) it 
places an 8- bit interrupt vector on the system 
data bus. The high- order five bits of this vector 



were written to the CTC during the program- 
ming process; the next two bits are provided 
by the CTC interrupt control logic as a binary 
code that identifies the highest priority chan- 
nel requesting an interrupt; the low-order bit 
is always zero. 

Interrupt Acknowledge Timing. Figure 14 
shows interrupt acknowledge timing. After an 
interrupt request, the Z-80 CPU s ends an inter- 
rupt acknowledge (Ml and lORQ). All chan- 
nels are inhibited from changing their inter- 
rupt request status when Ml i s activ e — about 
two clock cycles earlier than lORQ. RD is 
High to distinguish this cycle from an instruc- 
tion fetch. 

The CTC interrupt logic determines the 
highest priority channel requesting an inter- 
rupt. If the CTC interrupt enable input (lEI) is 
High, the highest priority interrupting channel 
within the CTC pla ces its interrupt vector on 
the data bus when lORQ goes Low. Two wait 
states (Twa) ^^e automatically inserted at this 
time to allow the daisy chain to stabilize. Addi- 
tional wait states may be added. 

Return from Interrupt Timing. At the end of 

an interrupt service routine the RETI (Return 
From Interrupt) instruction initializes the daisy 
chain enable lines for proper control of nested 
priority interrupt handling. The CTC decodes 
the 2-byte RETI code internally and determines 
whether it is intended for a channel being ser- 
viced. Figure 15 shows RETI timing. 

If several Z-80 peripherals are in the daisy 
chain, lEI settles active (High) on the chip 
currently being serviced when the opcode 
EDi6 is decoded. If the following opcode is 
4Di5, the peripheral being serviced is released 
and its lEO becomes active. Additional wait 
states are allowed. 
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Figure 14. Interrupt Acknowledge timing 



Figure IS. Return From Interrupt Timing 
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Absolute Voltages on any pin 

Maximum with respect to GND -0 . 3 V to + 7 . 0 V 

Ratings Operating Ambient Temperature . . 0 °C to 70 °C 
Storage Temperature -65 °C to +1 50 °C 



Stresses greater than those Hsted under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not imphed. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 



Standard 
Test 

Conditions 


The characteristics below apply for the 
lollowmg standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 




+ 5V 
< 2.1 K 




■ +4.75 V < < +5.25 V 


FROM OUTPUT 
UNDER TEST ^ 




■ GND = 0 V 

■ 0°C < Ta < +70°C 


50 pF? 






■ Output Test Circuit 








All ac parameters assume a load capacitance 
of 50 pF max. 







DC 

Character- 
istics 



Symbol 


Parameter 


Min 


Max 


Unit 


Test Condition 


ViLC 


Clock Input Low Voltage 


-0.3 


+ 0.45 


V 




ViHC 


Clock Input High Voltage 


Vcc-.6 Vcc + .3 


V 




ViL 


Input Low Voltage 


-0.3 


+ 0.8 


V 




VlH 


Input High Voltage 


+ 2.0 


Vcc 


V 


loL = 2 mA 


Vol 


Output Low Voltage 




+ 0.4 


V 


IoH= 250^A 


VoH 


Output High Voltage 


+ 2.4 




V 


ViN- = 0 to Vcc 


he 


Power Supply Current 




+ 120 


mA 


VouT = 2.4 to Vc 


Ili 


Input Leakage Current 




+ 10 




VouT = 0.4 V 


toH 


3-State Output Leakage Current in Float 




+ 10 


/xA 






3-State Output Leakage Current in Float 




-10 


fiA 




loHD 


Darlington Drive Current 


-1.5 




mA 


VoH = 1.5 V 



Rext = 390n 



Capacitance 


Symbol Parameter 




Max Unit 


Condition 




CLK Clock Capacitance 


20 pF 


Unmeasured pins 




Cjjq Input Capacitance 


5 pF 


returned to ground 




^OUT Output Capacitance 


10 pF 






Ta = 25°C, f = 1 MHz 








Ordering 




Maximum 






Information 


Part Number 


Clock Rate 


Temperature Range 


Package 




Z-80 CTC PS 


2.5 MHz 


0°Cto70°C 


Plastic 




Z-80 CTC CS 


2.5 MHz 


0°C to 70 °C 


Ceramic 




Z-80 CTC CE 


2.5 MHz 


-40 °C to 80 °C 


Ceramic 




Z-80 CTC CM 


2.5 MHz 


-55 °C to 125°C 


Ceramic 




Z-80A CTC PS 


4.0 MHz 


0°C to70°C 


Plastic 




Z-80A CTC CS 


4.0 MHz 


0°C to 70 °C 


Ceramic 




Z-80A CTC CE 


4.0 MHz 


-40°Cto80°C 


Ceramic 




Z-80ACTCCM 


4.0 MHz 


-55 °C to 125°C 


Ceramic 



C8085-0239 



AC 

Character- 
istics Number Symbol 



Parameter 



Z-80 CTC Z-80A CTC 
Min Max Min Max 
ns ns ns ns Comment 



1 

2 

3 

4 

5- 

6 

7 

8 

10 

11 

12 

13- 

14 

15 



TcC 
TwCH 
TwCl 
TfC 

-TrC— 

Th 

TsCS(C) 
TsCE(C) 

■ TsIO(C) 

TsRD(C) 

TdC(DO) 

TdC(DOz) 

•TsDI(C) 

TsMl(C) 
TdMl(IEO) 



16 TdlO(DOI)- 



17 
18 



TdlEI(IEOf) 
TdlEI(IEOr) 



19 TdC(INT) 

20 TdCLK(INT) 



21 

22- 

23 

24 

25 

26- 



TcCTR 
- TrCTR 

TfCTR 

TwCTRl 

TwCTRh 
■TsCTRfCs)- 



27 TsCTR(Ct) 



28 
29 



TdC(ZC/TOr) 
TdC(ZC/TOf) 



Clock Cycle Time 

Clock Width (High) 

Clock Width (Low) 

Clock Fall Time 
-Clock Rise Time ■ 

All Hold Times 

CS to Clock t Setup Time 

CE to Clock 1 Setup Time 
-lORQ I to Clock 1 Setup Time- 

RD 1 to Clock t Setup Time 

Clock 1 to Data Out Delay 

Clock 1 to Data Out Float Delay 

■ Data In to Clock I Setup Time — 

Ml to Clock t Setup Time 

Mi i to lEO 1 Delay (Interrupt 
immediately preceding Ml) 

■ lORQ I to Data Out Delay 

(INTA Cycle) 

lEI 1 to lEO i Delay 

lEI t to lEO I Delay 
(After ED Decode) 

-Clock t to INT 1 Delay 

CLK/TRG 1 to INT 1 
tsCTR(C) satisfied 
tsCTR(C) not satisfied 

CLK/TRG Cycle Time 

■ CLK/TRG Rise Time 

CLK/TRG Fall Time 
CLK/TRG Width (Low) 
CLK/TRG Width (High) 

■ CLK/TRG t to Clock \ Setup — 

Time for Immediate Count 

CLK/TRG I to Clock I Setup 
Time for enabling of Prescaler 
on following clock! 

Clock t to ZC/TO \ Delay 

Clock i to ZC/TO 1 Delay 



400 


[1] 


250 


[11 


170 


2000 


105 


2000 


170 


2000 


105 


2000 




30 




30 




30— 




30 



0 

250 
200 
■250- 
240 



-60- 
210 



0 

160 
150 
-115- 
115 



240 
230 



200 
110 



[2] 



-50- 

90 



300 
■340- 

190 



190 
-160- 

130 



[3, 5] 
■[2] — 



220 160 
■ (TcC + 200) — (TcC + 140)- 



(TcC + 230) (TcC + 160) 
(2TcC + 530) (2TcC + 370) 

(2TcC) (2TcC) 

50 50 

50 50 



[3] 
[3] 

-Timer mode — 

Counter mode 
Counter mode 

Counter mode 



200 
200 



200 
200 



300 



210 



210 



210 



Counter mode 



Timer mode 



260 
190 



190 
190 



NOTES: 

[1] TcC = TwCh + TwCl + TrC + TfC 

[2] Increase delay by 10 ns for each 50 pF increase in loading, 200 pF maximum for data lines and 100 pF for control lines. 
[3] Increase delay by 2 ns for each 10 pF increase in loading, 100 pF maximum. 
[41 RESET must be active for a minimum of 3 clock cycles. 



AC 

Character- 
istics 

(Continued) 



ftPv 



^ CSo, CSi 



READ < lORQ 



X 



-®- 



I 



<6> 



> 



WRITE < 



CSo, CSi 



X 



X 



X 



X 



<6> 



{ 



INTERRUPT / 
ACKNOWLEDGE \ lORQ 



> 



CLK/TRGo-3 

(COUNTER 
MODE) 



CLK/TRGo-3 

(TIMER 
MODE) 



ZC/TOo-2 



r 
J" 



1^ 



X 



JT 



-<20)- 



-<§>- 



X 



1 



X 



\ 



C8038-0169 



Package 
Information 

(Continued) 



0.598 
MAX 



PIN 1_ 
IDENTIFICATION 



1 



_0.530_ 
MAX 



0.012 
0.008 




0.125 
MIN 



I 0.065 I lo.llO ,1 0.1 



0.060 

0.020 



0.065 
0.035 
BOTH ENDS 



,021 
0.015 



28-Pin Ceramic Package 




TOWWVWWVW" 



1.470 
MAX 




28-Pin Plastic Package 



